package com.atguigu.gulimall.gulimallseckill;

import org.springframework.amqp.rabbit.annotation.EnableRabbit;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;

/**
 * 1、整合Sentinel
 *      1)、导入依赖 spring-cloud-starter-alibaba-sentinel
 *      2)、下载sentinel 的控制台
 *      3)、配置sentinel的控制台的信息
 *      4)、在控制台调整参数,默认所有的流控设置保存在内存中,重启失效
 * 2、每一个微服务都导入actuator ,并且配合management.endpoints.web.exposure.include=*
 * 3、自定义sentinel的流控返回数据
 * 4、使用Sentinel来保护feign远程调用,熔断:
 *      1)、调用方的熔断保护,feign.sentinel.enabled = true
 *      2)、调用方指定远程调用的降级策略，远程服务被降级处理,触发我们的熔断回调方法
 *      3)、超大浏览的时候,必须牺牲一些远程服务,在服务的提供方（远程服务）指定降级策略
 *      提供方是在运行，但是不运行自己的业务逻辑,返回的是默认的熔断数据（限流数据）
 * 5、自定义受保护的资源
 *     1、
 *     try(Entry entry = SphU.entry("seckillSkus")){
 *
 *      }catch (BlockException e) {
 *           log.error("资源被限流",e.getMessage());
 *      }
 *      2、基于注解
 *          @SentinelResource(value = "getCurrentSeckillSkusResource",blockHandler = "blockHandler")
 *      无论是1,2方式一定要配置被限流以后的默认返回
 *      url请求可以设置统一返回
 */
@EnableRabbit
@EnableRedisHttpSession
@EnableFeignClients
@EnableDiscoveryClient
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
public class GulimallSeckillApplication {

    public static void main(String[] args) {
        SpringApplication.run(GulimallSeckillApplication.class, args);
    }

}
